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(54) ATM crossbar switch fabric 

(57) An expandable, self routing switching fabric 
routes data packets in an ATM switch (1 0). A crosspoint 
array of state machines (Fig. 2) disposed at internal in- 
tersections of input ports ( 1 4) and output ports have pre- 
determined identities (Fig. 3) representative of the out- 
put ports (16) and include a comparator for identifying 
an address header of each data packet with the state 
machine identity. When a match occurs (Fig. 2), the 



state machine is set active/connected and when a non- 
match occurs, the state machine is set not-active/dis- 
connected. A circuit through the fabric is set by connec- 
tion between an input port (14) through an active/con- 
nected state machine to a desired output port (1 6). The 
predetermined identity of each state machine (Fig. 2) 
comprises a hard wired bit sequence (Fig. 3) common 
to the column including the state machines. 
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Description 

This invention relates to high-speed, broadband 
communication networks and, more particularly, to a self 
routing crossbar switch suitable for communicating data 
packets in an ATM switch. 

High-speed, broad-band communication networks 
include systems for routing data packets from input 
sources to output sources. US-A-s 5,305,311 and 
5,327,420 disclose such switching networks. The basic 
architecture of such prior art systems include an Asyn- 
chronous Transfer Mode (ATM) Local Area Network 
(LAN) using a VLSI-based "Batcher/banyan* switching 
fabric of the type which has been developed by 
AT&T/Bellcore. Batcher/banyan switching technology 
will scale to switches larger than 256 ports, and link rates 
exceeding 1 gigabit/sec and these switches can be in- 
terconnected to form a larger hierarchical network for 
supporting larger user communities. 

An advantage of such Batcher/banyan switch fab- 
rics is that they are "self routing". That is, data packets 
are routed through the switching fabric on the basis of 
local decisions only, there is no global "chokepoint". For 
each stage in the network, routing can be determined 
with only the information contained in the data packets 
entering that stage of the switch; that is, with locally 
available information. Such networks are also advanta- 
geous when they are "non-blocking". In any switching 
cycle, the network is capable of generating an arbitrary 
permutation, or a partial permutation, of its inputs. More 
simply stated, a nonblocking switching fabric is able to 
generate all possible one to one input/output mappings 
in a single switching cycle. 

Ideally such a switching fabric provides parallelism 
whereby a single N port Batcher sorting network can 
feed some number k (typically two or three) banyan rout- 
ing switches that are connected so that as many as k- 
cells can be routed to the same number of output ports 
during the same cell switching cycle without losing any 
of the data packets. However, in order to overcome the 
problem that occurs when more than one data packet is 
found to be destined to the same output port during the 
single switch cycle, a "reservation ring" is provided for 
fairly adjudicating the contention among such conflicting 
data packets, while permitting at most k of them to be 
presented to the switch in any cycle. Reservation rings 
resolve output contentions among conflicting data pack- 
ets, while implementing "fair" access to the output ports 
of the switching fabric. 

The first bits of a data packet contain the address 
to which the packet should be routed. Such "first bits" 
are typically referred to as the "header", and identify the 
path through the switching fabric, the source and desti- 
nation of which are input and output ports. For a partic- 
ular switch, the input and output ports associated with 
a given virtual circuit are defined at connection estab- 
lishment. A virtual circuit is thus the ultimate source and 
ultimate destination, and all the intermediate switches 



therebetween defining the path through the fabric. Ac- 
cordingly, the contents of the header are defined by the 
virtual circuit as the path through the particular switching 
fabric. Switching fabric such as Batcher/banyans allow 

5 many possible paths between any given input and out- 
put pair and present a problem which is sought to be 
overcome by the present invention. The problem is that 
it is very difficult to diagnose failures in a Batcher/ban- 
yan switch fabric due to the multiple possible paths. A 

10 failure is difficult to replicate because of the many pos- 
sible paths. 

The present invention contemplates a new and im- 
proved switching fabric to replace the Batcher/banyan 
network of prior art systems, provide easier diagnosis 

15 of failures in the fabric than in the Batcher/banyan net- 
work, is simple in design, economical to manufacture 
and which provides better scaling properties than a 
Batcher/banyan for the size of the switching fabrics that 
the subject invention is applicable to be implemented as 

20 in a commercial embodiment. 

In accordance with the present invention, there is 
provided an expandable, self routing switching fabric for 
routing data packets in an ATM switch comprising: a plu- 
rality of input ports and a plurality of output ports for rout- 
es jng the packets from input sources coupled to said input 
ports to output destinations coupled to said output ports 
on circuits through the fabric specified by the packets; 
and a crosspoint array of state machines disposed at 
internal intersections of the input ports and the output 

30 ports, wherein each state machine has a predetermined 
identity representative of a one of the output ports and 
includes a means for comparing the identity to an ad- 
dress header of each data packet and for setting each 
state machine active/connected when the comparing 

35 determines a match between the identity and the ad- 
dress header and for setting each state machine not ac- 
tive/disconnected when the comparing determines a 
non-match between the identity and the address head- 
er, whereby a selected circuit through the fabric to a de- 

40 sired output port comprises an active/connected state 
machines in connection from a one of the input ports to 
the desired output port. 

The switching fabric of the invention comprises a 
crosspoint array wherein the input ports comprise a plu- 

45 rality of rows and the output ports comprise a plurality 
of columns. The selected circuit is the input row and the 
output column through the active/connected state ma- 
chine defined by the desired output port. 

In accordance with a more limited aspect of the sub- 

50 ject invention, the predetermined identity of each state 
machine comprises a hard-wired bit sequence common 
to the column including the active/connected state ma- 
chines defined by the desired output port. 

One benefit obtained by the present invention is an 

S5 ATM switch fabric which is simple in design and thus 
easier to diagnose for failures than prior art Batch- 
er/banyan crossbar switches. 

Another benefit obtained by the present invention 
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is a switching fabric which has better scaling properties 
for small scaling values. 

The invention may take physical form in certain 
parts and arrangements of parts, the preferred embod- 
iments of which will be described in this specification 
and illustrated in the accompanying drawings which 
form a part hereof, and wherein: 

FIGURE 1 is a diagrammatic illustration of a cross- 
bar chip : of size N x N, as intended as part of the 
present invention; 

FIGURE 2 defines the possible states of each state 
machine at the crosspoints of the chip of FIGURE 1 ; 
FIGURE 3 illustrates a tabular sequence for com- 
paring an address identity of an output port or col- 
umn against header information of the eel! packet; 
FIGURE 4 illustrates an array of the crossbar chips 
of FIGURE 1 connected to form a switching fabric 
2N x 2N: 

FIGURE 5 shows an expanded switching fabric of 
the crossbar chips of FIGURE 1 having a speed-up 
of 2; 

FIGURE 6 is a tabular illustration of the sequence 
for comparing header information against column 
identity in an 8 by 8 switching fabric with a speed- 
up of 2; 

FIGURE 7 shows a standard form synchronous 
state machine such as can be employed in the 
crosspoint array of the subject invention: and : 
FIGURE 8 is a tabular definition of the state 
machine of FIGURE 7. 

Referring now to the drawings, the various FIG- 
URES show a self routing crossbar switch suitable for 
use as a switching fabric in an ATM switch. The inven- 
tion is particularly applicable to replace the Batcher/ban- 
yan network in a system such as is shown in US-A- 
5,327,420. 

The basic architecture of such a system is directed 
to high-speed, parallel transmission and switching of 
small, fixed sized data packets, called 'cells". The first 
bits of each data packet, called a "header" , contain an 
address indicative of an output port to which the packet 
should be routed. 

FIGURE 1 illustrates a crossbar chip 10 represent- 
ing a fundamental element of the fabric, of size N x N, 
where N is a power of 2, which forms an N by N switching 
fabric. The fabric comprises a crosspoint array in which 
the crosspoints 12 are located at intersections of an in- 
put row 14 and output column 16. The inputs are illus- 
trated as ranging from l 0 to l n . t and similarly, the outputs 
are represented as ranging from O 0 to O n . v It is, of 
course, the overall objective of the invention to transmit 
a cell from a one of the input ports through the fabric to 
a desired output port in a quick and reliable manner. 

For such an ATM switch, each cell will be presented 
bits serially, most significant bit first, and will have the 
header pre-pended to the cell. Presentation of the cells 



will occur synchronously at all inputs 14. Thus, the self 
routing crossbar chip can compare all cell headers in 
lock step. If a given input is inactive during a cell time, 
it still presents a dummy cell, with the leading bit set to 
5 "0" to denote "inactive". 

The address is in a form to identify the output col- 
umn 16 to which the cell should be routed out within the 
N x N chip. Each chip 10 has N 2 internal intersections 
at the crosspoints between the rows and the columns. 
io At each of the intersections is disposed a state machine 
having an operating character as shown in FIGURE 2. 
The most significant bit of a field of the cell is transmitted 
first on the rows 14. At each state machine at the cross- 
points 1 2, each bit of the address is compared against 
15 a hard wired bit sequence common to the column of the 
intersection. The sequence comprises a predetermined 
identity representative of the output port common to all 
state machines of the particular column. The array is 
completely regular if the address generated for each 
20 state machine is common to the column and not present 
at each state machine. If at any step in the sequential 
comparison the state machine makes a determination 
of "not-equal", then the state machine goes "not-ac- 
tive/disconnected". At the end of the addresses, only the 
25 active state machines can connect a particular row to 
the desired column output. In the case of maximum op- 
erating efficiency of the fabric, N cells, each on a one of 
the input rows, can be individually connected to the N 
output ports for simultaneous transmission through the 
30 switching fabric. In order to avoid conflicting cells seek- 
ing output to the same port, a reservation ring (not 
shown) insures that only one row will address a desired 
column, so that only one input will drive a given output. 
With particular reference to FIGURE 3, a more de- 
35 tailed illustration of the subject invention is shown 
wherein a 4 by 4 switching fabric with columns num- 
bered "00" through "11" are shown. It can be seen that 
the address comparing occurs in three time steps. Dur- 
ing time step 0, the most significant bits are set to "1" to 
to indicate that the cell is active. If the cell were inactive, 
the most significant bit would be set to "0". During time 
steps 1 and 2, the column is selected within the chip. It 
can be seen that the first column is identified by the se- 
quence "00" and the fourth column is identified by the 
45 sequence "11". Thus, all rows will be compared against 
the sequence "100" for column "00" and against se- 
quence "1 1 r for column "1 1 tt . 

It is an important feature of the invention that the 
switching fabric 1 0 can be generalized to both larger f ab- 
50 rics than are possible with a single chip and to fabrics 
where there is a speed-up of k from the inputs to the 
outputs (analogous to the speed-up of k achievable with 
k banyans in a Batcher/banyan network). 

FIGURE 4 shows an array 20 of four of the crossbar 
55 chips 10, each N by N in size, where N is a power of 2, 
connected to form a switching fabric of 2N x 2N. The 
chips 10 are connected in 2 columns 22, 24 of two N by 
N crossbars, each crossbar column is given an identity 
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by means of pins tied to ground or VCC. Thus, in addi- 
tion to each individual output port having an identity, the 
two columns each have an identity as well. Also, as with 
Batcher/banyan networks, a speed-up of k can be 
achieved by multiplying the number of columns by k. For 
example, FIGURE 5 shows such a circuit with 2N inputs 
and 2 x 2 N outputs for a speed-up value of k = 2. The 
identity of the desired output port is represented by a 
single address in the form: [cell active/inactive, value of 
k, chip column, column within an N x N chip], so that 
each input to the switching fabric identifies by its ad- 
dress the desired output port. 

With reference to FIGURES 5 and 6, the above ad- 
dress form can be specifically illustrated. FIGURE 5 
shows an 3 by 8 switching fabric with a speed-up of 2. 
There are sixteen columns spread across four columns 
of 4 by 4 chips, with the individual columns numbered 
"OOOO" through "1111". In FIGURE 6, the sequence for 
comparing cell address against the identity of each col- 
umn is shown. Thus, all rows will be compared against 
the sequence "10000" for column "0000" and against 
"11111" for column "1 1 1 r. In time step 0, a comparison 
occurs to determine whether the cell is active or not ac- 
tive. In time step 1, the k value comparison occurs. In 
time step 2, the chip column comparison occurs and in 
time steps 3 and 4, the select column within each of the 
chips comparison occurs. 

With reference to FIGURES 7 and 8, one possible 
hardware permutation of a state machine having a state 
diagram as illustrated in FIGURE 2 is shown. A state 
machine as shown in FIGURE 7 will be disposed at each 
crosspoint 12 (FIGURE 1) in the switching fabric 10. 
FIGURE 8 provides a detailed definition of function for 
the state machine in FIGURE 7. This implementation re- 
quires approximately twelve gate equivalents. A 129 by 
128 self routing crossbar switch could be easily imple- 
mentable using standard cell technology. 

A particular advantage of the present invention is 
that it is easier to diagnose failures in the switching fab- 
ric than in prior known Batcher/banyan networks. In par- 
ticular, such prior art systems required each switching 
point to examine one or more of the cell header address 
bits to decide how to subsequently route the rest of the 
packet. The resulting virtual circuit was complex and it 
was hard to identify where failure occurred. The present 
invention overcomes this problem by providing a simpli- 
fied system wherein a failure can be located at the state 
machine in the column of the fabric common to the de- 
sired output port. 

Another advantage of the present invention is its 
ability to be readily expandable with better scaling prop- 
erties. For example, a 2N Batcher/banyan network re- 
quires ten chips as opposed to the eight chips for a com- 
parable self routing crossbar switch manufactured in ac- 
cordance with the subject invention. Although it will be 
appreciated by one of ordinary skill in the art that for 
large N switching fabrics a Batcher/banyan may scale 
better than the subject invention. 



Claims 

1 . An expandable, self routing switching fabric for rout- 
ing data packets in an ATM switch comprising: 

5 

a plurality of input ports (14) and a plurality of 
output ports (16) for routing the packets from 
input sources coupled to said input ports to out- 
put destinations coupled to said output ports on 
10 circuits through the fabric specified by the pack- 

ets; and, 

a crosspoint array of state machines (Fig. 2) 
disposed at internal intersections of the input 
ports (14) and the output ports (16), wherein 

15 each state machine has a predetermined iden- 

tity representative of a one of the output ports 
and includes a means for comparing the iden- 
tity to an address header of each data packet 
and for setting each state machine active/con- 

20 nected when the comparing determines a 

match between the identity and the address 
header and for setting each state machine not 
active/disconnected when the comparing 
determines a non-match between the identity 

25 and the address header, 

whereby a selected circuit through the fabric to 
a desired output port (16) comprises an 
active/connected state machines (Fig. 2) in 
connection from a one of the input ports ( 1 4) to 

30 the desired output port. 

2. The switching fabric as defined in claim 1 wherein 
the input ports (14) comprise a plurality of rows of 
the crosspoint array and the output ports (16) com- 

3S prise a plurality of columns of the crosspoint array 
and wherein the selected circuit comprises a one of 
the columns of active/connected state machines 
(Fig. 2) defined by the desired output port. 

40 3. The switching fabric as defined in claim 2 wherein 
the predetermined identity of each state machine 
(Fig. 2) comprises a hardwired bit sequence (Fig. 
3) common to the one of the columns including said 
each state machine. 

45 

4. The switching fabric as defined in claim 1 , 2 or 3 
wherein the switching fabric comprises an N plural- 
ity of input ports (14) and a kN plurality of output 
ports (16) where k represents a speed up of the 

so switching fabric from the input ports to the output 
ports. 

5. The switching fabric as defined in claim 4 wherein 
the address header comprises a form representa- 

55 tive of data packet active/inactive, a value of k, a 
chip column and column within an N x N chip, 
wherein the switching fabric is comprised of a plu- 
rality of N x N chips. 
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